//125. 验证回文串
//已解答
//简单
//相关标签
//premium lock icon
//相关企业
//如果在将所有大写字符转换为小写字符、并移除所有非字母数字字符之后，短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。
//
//字母和数字都属于字母数字字符。
//
//给你一个字符串 s，如果它是 回文串 ，返回 true ；否则，返回 false 。
class Solution {
public:
    bool isDigitOrWord(char ch)
    {
        if (ch >= '0' && ch <= '9' || ch >= 'A' && ch <= 'Z' || ch >= 'a' && ch <= 'z')
            return true;
        return false;
    }
    bool isPalindrome(string s) {
        for (int i = 0; i < s.size(); i++)
        {
            s[i] = tolower(s[i]);
        }
        int left = 0;
        int right = s.size() - 1;
        while (left < right)
        {
            while (left < right && !isDigitOrWord(s[left])) left++;
            while (left < right && !isDigitOrWord(s[right])) right--;
            if (s[left] != s[right]) return false;
            left++;
            right--;
        }
        return true;
    }
};